草庐IT

SpringSecurity 安全框架详解

全部标签

javascript - 将 'arguments' 传递给 'apply()' 是否安全

假设我有以下代码(完全没用,我知道)functionadd(a,b,c,d){alert(a+b+c+d);}functionproxy(){add.apply(window,arguments);}proxy(1,2,3,4);基本上,我们知道apply需要一个数组作为第二个参数,但我们也知道arguments不是一个正确的数组。代码按预期工作,所以可以肯定地说我可以将任何类似数组的对象作为apply()中的第二个参数传递吗?以下内容也可以使用(至少在Chrome中):functionproxy(){add.apply(window,{0:arguments[0],1:argumen

javascript - 依赖 Content-Type : text/plain to mitigate malicious javascript execution in response? 是否安全

我们有一个返回的web应用程序HTTP/1.1400BadRequest...Content-Type:text/plain;charset=UTF-8Content-Length:57Date:Tue,14Apr201519:24:54GMTConnection:closeInvalidprojectareaitemidalert(1086)据我了解,依靠Content-Type:text/plain;charset=UTF-8作为防御来阻止javascript执行是不够的。相反,应该对输出进行编码,并且应该对输入进行输入验证并丢弃垃圾。我正在寻找的是关于处理具有javascript

javascript - AJAX 跨域安全背后的基本原理是什么?

考虑到编写跨域获取数据的服务器端代理的简单性,我不知道阻止客户端AJAX跨域调用的最初意图是什么。我不是在寻求猜测,我是在寻找语言设计者(或与他们关系密切的人)的文档,了解他们认为自己在做什么,而不仅仅是给开发人员带来轻微的不便。TIA 最佳答案 防止浏览器充当反向代理。假设您正在浏览http://www.evil.com从您办公室的PC上,并假设该办公室中存在一个包含敏感信息的内部网http://intranet.company.com只能从本地网络访问。如果跨域策略不存在,www.evil.com可以向http://intran

javascript - Web Workers 是一种安全的方式来沙盒不受信任的 JavaScript 代码吗

我想知道WebWorker是否是对不受信任的JavaScript代码进行沙盒处理的安全方法。例如,在绘图应用程序的上下文中,开发人员可以在其中实现新的绘图工具,您可以将他们的代码放入webworker中,并且每当用户单击Canvas时,向他们发送包含光标位置的JSON消息,以及图像数据数组,当脚本完成时,它会传回一条包含新图像数据的消息。这是否安全,或者是否存在我没​​有想到的风险? 最佳答案 DOM对Webworker不可用,但可以访问同源内容,例如indexedDB。请参阅我的相关问题:Canworkersbesecureeno

javascript - Microsoft Edge 不接受内容安全策略的哈希

问题Content-Security-Policy应该默认将脚本和样式解析列入黑名单,并允许它基于各种指令来验证预期输出的哈希值。浏览器必须无法实现任何未预先提供匹配哈希的Javascript或CSS。具有匹配散列的代码应正常执行。MicrosoftEdge拒绝所有JS/CSS页内block。说明在MicrosoftEdge和任何其他浏览器中访问下面的实时演示链接。现场演示:http://output.jsbin.com/biqidoqebu演示原始源码#loading{color:transparent}#loading:after{color:green;content:"Styl

javascript - Meteor JS 是否可以灵活地成为全栈框架?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我已经阅读了一些关于JavaScriptMV*框架的有趣文章和比较,并且我知道最流行的框架(Ember、Backbone、Angular)的大纲但是作为一名PHP程序员(和Symfony2情人)谁想详细了解其中一个,我关心的是Meteor(我的第一选择)足够灵活,可以被认为是一个完整的堆栈框架,因此我可以在大多数基本应用程序上完全放弃服务器端(例如PHP)

javascript - 玩!框架 : Best practice to use URLs in separate JavaScript files?

我目前正在重组Play!有很多JS的项目HTML模板文件中的代码。此代码应移至外部JS文件以获得更好的可读性和更快的页面加载时间。然而,当我在公共(public)文件夹中创建一个JS文件时,所有@{Controller.method}链接替换不再有效。我曾是考虑从HTML调用一些初始化函数仅提供所需URL的模板,例如initialize({"Application.doThis":"@{Application.doThis}"})然而,这对于任何URL都变得非常麻烦且容易出错即已添加。另一件事是,I18N也不再有效。所以对于这样的场景,您有自己的最佳实践是什么单独文件中的JS代码,但仍

javascript - Node.js 休息框架

我计划使用JavaScript编写一个相当大型的Web应用程序。我相信我将使用CanJS开发webapp来组织我的客户端部分。我强烈考虑将Node.js用于我的服务器端组件,但我想知道设置Node以接受和处理REST请求的最佳方法是什么。我做了一些谷歌搜索,发现了一个叫做Express的东西。对此有何评论?如有任何帮助/建议,我们将不胜感激。 最佳答案 restifyisanode.jsmodulebuiltspecificallytoenableyoutobuildcorrectRESTwebservices.http://mca

javascript - 使用正则表达式验证字符串是否是 URL 安全的

我有一个网站,用户可以在其中选择用户名。目前,他们几乎可以输入任何字符,包括@!#等等我知道我可以使用正则表达式,这可能就是我要选择的。我将使用一个否定集,我假设它是正确的工具:[^@!#]那么,我怎样才能知道要放入那个集合中的所有非法字符呢?我可以开始手动放入那些显而易见的东西,例如!@#$%^&*(),但是有没有一种简单的方法可以做到这一点而无需手动将它们中的每一个都放入?我知道很多网站只允许包含字母、数字、破折号或下划线的字符串。类似的东西对我来说很管用。如有任何帮助,我们将不胜感激。谢谢S.O.! 最佳答案 不使用否定,只将

javascript - 缩小版本的 jQuery 或 Prototype - JS 框架选择

在为我的下一个项目考虑JS框架时,我可以看到明显倾向于jQuery的规模,但是,Prototype也获得了好评。我正在考虑的问题是如何缩小这些以仅具有我真正需要的功能。最新的jQuery似乎压缩了55k,例如,我显然只需要非常基本的主要需要的功能或跨浏览器兼容性。手动编写我需要的代码的替代方案听起来很痛苦。有没有人遇到过“jQuerydownscaler”或“Prototypedownscaler”?像Dlite这样的东西并没有完全解决它,因为我需要带超时的跨浏览器AJAX和跨浏览器cookie处理,但也许还有其他一些轻量级解决方案?与ASP相关的bundle无济于事,因为我正在做一个